

## ⑫ 公開特許公報(A)

平3-98145

⑬ Int.Cl.<sup>5</sup>G 06 F 13/36  
15/78

識別記号

3 2 0 B  
5 1 0 F

府内整理番号

8840-5B  
9072-5B

⑭ 公開 平成3年(1991)4月23日

審査請求 未請求 請求項の数 3 (全7頁)

⑮ 発明の名称 マイクロプロセッサ

⑯ 特願 平1-235446

⑰ 出願 平1(1989)9月11日

⑱ 発明者 塚元卓 東京都小平市上水本町5丁目22番1号 日立マイクロコンピュータエンジニアリング株式会社内

⑲ 出願人 株式会社日立製作所 東京都千代田区神田駿河台4丁目6番地

⑲ 出願人 日立マイクロコンピュータエンジニアリング株式会社 東京都小平市上水本町5丁目22番1号

⑳ 代理人 弁理士 德若光政

## 明細書

## 3. 発明の詳細な説明

## (産業上の利用分野)

この発明は、マイクロプロセッサに関し、例えば可変長のデータを取り扱うマイクロプロセッサを利用して有効な技術に関するものである。

## (従来の技術)

従来のマイクロプロセッサでは外部データバス幅が固定されるものである。例えば、インテル社の「マイクロプロセッサ8088」とモトローラ社の「マイクロプロセッサ68008」は外部8ビットバスであり、インテル社の「マイクロプロセッサ8086」とモトローラ社の「マイクロプロセッサ68000」は外部16ビットバスである。これらは共に内部は16ビットバスアーキテクチャを探っている。つまり、外部16ビットバス構成の「マイクロプロセッサ8086や68000」では8ビットバスの周辺デバイスが接続できない。これを解決する手段として、以下の2つの方法が探られている。

1つの方法は、「マイクロプロセッサ68000

## 1. 発明の名称

マイクロプロセッサ

## 2. 特許請求の範囲

1. 内蔵のレジスタによって特定アドレス領域を指定し、この特定アドレス領域内に対するアクセスの認識結果に応じてデータバス幅及び／又はバスサイクルを動的に変化させる機能を付加したことを特徴とするマイクロプロセッサ。

2. 上記特定アドレス領域の指定は、特定のモード信号によって比較されるアドレスビットが指定されるものであることを特徴とする特許請求の範囲第1項記載のマイクロプロセッサ。

3. 上記マイクロプロセッサは、16ビットアーキテクチャにより設計されるものであり、上記特定アドレス領域には8ビットアーキテクチャによる周辺装置が設けられ、この周辺装置とのデータの授受が8ビットの単位で行われるものであることを特徴とする特許請求の範囲第1又は第2項記載のマイクロプロセッサ。

0」にみられるような VPA 信号による方法である。これは、丸善謹、昭和58年3月30日発行「68000マイクロコンピュータ（マイクロコンピュータシリーズ14）」にあるように、セレクトされたデバイスが 68000周辺LSIであることをマイクロプロセッサに知らせるための信号である。マイクロプロセッサは、この信号を受けると8ビットバスインターフェイスを探る。他の方法は、「マイクロプロセッサ HD 641016」にみられる MOVTP 命令による方法である。これは、謹日立製作所、昭和62年9月発行「HD 641016ユーザーズマニュアル」にあるように、当該命令のデータ転送サイクルのみ8ビットバスインターフェイスを探るものである。当然双方向のデータ転送が必要なため命令MOVTP の他に MPVFP が用意されている。

#### (発明が解決しようとする課題)

上記 VPA 信号による方法では、マイクロプロセッサが output したアドレスを外部でデコードし、VPA 信号としてマイクロプロセッサに返す必要

り換えるので高速でかつ、汎用性をもったバスサイズの切り換えが可能になる。

#### [実施例]

第1図には、この発明に係るマイクロプロセッサの一実施例のブロック図が示されている。同図の各回路ブロックは、公知の半導体集積回路の製造技術によって、特に制限されないが、単結晶シリコンのような1個の半導体基板上において形成される。

マイクロプロセッサMPU は、前記外部 16 ビット構成のマイクロプロセッサである。このような 16 ビット構成のマイクロプロセッサが構成される半導体集積回路装置 LSI に対して、動的なバスサイズ切り換えを可能にするため、言い換えるならば、外部 16 ビットのバス SDB に、8 ビットアーキテクチャによる周辺デバイスを搭載し、それとのデータの授受の高速に行うようするため、以下の各回路ブロックが内蔵される。

レジスタ RA と RB は、それぞれ 1 ビット以上のビット幅を持ち、アドレス領域指定に用いられ

があるため高速動作が期待できないという問題がある。上記 MOVTP 命令による方法では、特定の命令しか利用できないという問題がある。

この発明の目的は、高速にしかも汎用性を持つてバスサイズを動的に切り換える可能としたマイクロプロセッサを提供することにある。

この発明の前記ならびにそのほかの目的と新規な特徴は、本明細書の記述および添付図面から明らかになるであろう。

#### (課題を解決するための手段)

本願において開示される発明のうち代表的なものの概要を簡単に説明すれば、下記の通りである。すなわち、内蔵のレジスタによって特定アドレス領域を指定し、この特定アドレス領域内に対するアクセスを認識してその結果に応じてデータバス幅を動的に切り換える。

#### (作用)

上記した手段によれば、マイクロプロセッサ自身が指定アドレスと上記設定された特定アドレス領域であるかを認識し、それに応じてバス幅を切

り換えるので高速でかつ、汎用性をもったバスサイズの切り換えが可能になる。

このレジスタ RA と RB は、マイクロプロセッサ MPU が持つ各種レジスタと同様に特定のアドレスが割り当てられて、内部のデータバス DB と接続されている。これにより、マイクロプロセッサ MPU からレジスタ RA と RB の書き込みによって任意のアドレス指定が可能にされる。

レジスタ RA に保持されたアドレス情報は、コンパレータ CPA に入力される。レジスタ RB に保持されたアドレス情報はコンパレータ CPB に入力される。これらのコンパレータ CPA と CPB の他方の入力には、内部アドレスバス AB を通して、マイクロプロセッサ MPU がアクセスしようとしているアドレス信号が供給される。コンパレータ CPA と CPB は、入力信号の大小又は一致信号を出力する。これらの信号大小又は一致信号はマイクロプロセッサ MPU に伝えられ、両コンパレータ CPA と CPB の比較出力結果から、上記アクセスしようとしているアドレスが、上記

レジスタ R A と R B によって指定された特定アドレス領域か否かの識別が行われる。この識別結果は、制御信号 B S に反映される。

上記内部データバス D B と外部データバス（システムバス）S D Bとの間には、入出力バッファ I O B が設けられる。この I O B は、上記制御信号（バス幅セレクト信号）B S により後述するようなバス幅切り換を行う。

外部から供給されるモード信号 M D は、上記コンバレータ C P A と C P B に供給される。例えば、モード信号 M D によりモード 1 を指定したとき、アドレスバス A B は、16 ビットからなるアドレス信号を出力し、約 64 K バイトの領域をアクセス可能としている。モード信号 M D によりモード 2 を指定したとき、24 ビットからなるアドレス信号を出力し、約 16 M バイトの領域をアクセス可能としている。

領域指定用レジスタ R A と R B が上記のように 8 ビット幅を持っている場合、それに対応したコンバレータ C P A と C P B の入力も 8 ビット幅を

ドレス空間を示す概念図が示されている。

レジスタ R A によりアドレス A 1 を指定し、レジスタ R B によりアドレス A 2 を指定すると、同図において斜線を付したようにアドレス A 1 からアドレス A 2 までの領域が設定されることになる。上記アドレス A 1 から A 2 までのアドレス指定を行うと、上記コンバレータ C P A と C P B の比較出力から、マイクロプロセッサ M P U は上記指定領域か否かを判定し、上記アドレス指定領域ならば、制御信号 B S を形成して 8 ビットバスでのインターフェイスに切り換える。上記指定領域以外ならば 16 ビットのバスインターフェイスとするものである。

第 3 図には、上記バス幅切り換え機能を持つ入出力バッファ I O B のうち出力経路の一実施例の回路図が示されている。

内部データバスの信号 D 0 ~ D 15 を外部端子 O U T 0 ~ O U T 15 へ送出する出力回路 D O B 0 ないし D O B 15 の前段に、特に制限されないが、クロックドインバータ回路（3 状態出力回

持っている。したがって、モード 1 が指定されたとき、コンバレータ C P A と C P B に入力される 8 ビットからなるアドレス信号は、16 ビットからなるアドレス信号のうち上位 8 ビット（8 ~ 15）とされる。つまり、レジスタ R A と R B により指定される領域指定の単位は 256 バイトとなる。例えば、レジスタ R A と R B に同じアドレスを入力すると、それを上位 8 ビットのアドレスとして、256 バイトの領域が指定されることになる。

これに対して、モード 2 が指定されたとき、コンバレータ C P A と C P B に入力される 8 ビットからなるアドレス信号は、24 ビットからなるアドレス信号のうち上位 8 ビット（16 ~ 23）とされる。つまり、レジスタ R A と R B により指定される領域指定の単位は約 64 K バイトとなる。例えば、レジスタ R A と R B に同じアドレスを入力すると、それを上位 8 ビットのアドレスとして、約 64 K バイトの領域が指定されることになる。

第 2 図には、上記レジスタにより指定されるア

路）により構成されたマルチプレクサ回路が設けられる。すなわち、内部データバスの信号 D 0 ~ D 7 は、代表として例示的に示されているクロックドインバータ回路 C N 0 と C N 1 を介して対応する出力回路 D O B 0 ~ D O B 7 の入力に供給される。

これに対して、内部データバスの上位 8 ビットの信号 D 8 ~ D 15 は、一方において代表として例示的に示されているクロックドインバータ回路 C N 2 と C N 3 を介して 16 ビットのバス幅の上位 8 ビットに対応する出力回路 D O B 8 ~ D O B 15 の入力に供給され、他方において代表として例示的に示されているクロックドインバータ回路 C N 4 と C N 5 を介して 8 ビットのバス幅に対応する上記出力回路 D O B 0 ~ D O B 7 の入力に供給される。

上記クロックドインバータ回路 C N 0 と C N 1 の制御端子には制御信号 L が供給される。上記クロックドインバータ回路 C N 2 と C N 3 の制御端子には制御信号 U が供給される。そして、クロック

クロックドインバータ回路CN4とCN5の制御端子には制御信号U'が供給される。上記各クロックドインバータ回路CN0ないしCN5は、それぞれ対応する制御信号L、U及びU'がハイレベル（論理“1”）のとき動作状態になり信号伝達動作を行い、それぞれ対応する制御信号L、U及びU'がロウレベル（論理“0”）のとき出力ハイインピーダンス状態にされる。

また、出力回路DOB0ないしDOB15は、出力制御信号DOCによりその動作が制御される。例えば、メモリのライトライクルのようにデータを出力するとには、出力制御信号DOCがハイレベルにされる。これに応じて、出力回路DOB0ないしDOB15が動作状態になって、マイクロプロセッサMPUで生成した書き込みデータ等を出力する。これに対してメモリのリードサイクルのようにデータを入力するときには、出力制御信号DOCがロウレベルにされる。これに応じて、出力回路DOB0ないしDOB15が出力ハイインピーダンス状態になり、図外のデータ入力回路

が動作状態になってシステムバスADBから送られてきたデータの取り込みを行う。

第4図には、上記入出力バッファI/OBの動作の一例を示すタイミング図が示されている。マイクロプロセッサMPUが、第2図のようにな16ビットのバスインターフェイス領域のアドレス空間をアクセスしようとすると、コンパレータCPAとCPBの出力から16ビットのバス幅領域であることを認識し、制御信号BSとして、信号U及びLを論理“1”に制御信号U'を論理“0”にする。これにより、上記クロックドインバータ回路CN0とCN1及びCN2とCN3が動作状態になる。したがって、内部データバスDBの下位8ビットの信号D0～D7は、代表として例示的に示されたクロックドインバータ回路CN0とCN1を通して出力下位DOB0～DOB7の入力に伝えられる。内部データバスDBの上位8ビットの信号D8～D15は、代表として例示的に示されたクロックドインバータ回路CN2とCN3を通して出力回路DOB8～DOB15の

入力に伝えられる。これにより、出力制御信号DOCに従い出力回路DOB0～DOB15の動作状態に応じて、1メモリサイクル中にD0～D7及びD8～D15からなる16ビットのデータが出力端子OUT0～OUT15を通して16ビット幅のシステムバスADBへ送出される。

マイクロプロセッサMPUが、第2図のようにな8ビットのバスインターフェイス領域のアドレス空間をアクセスしようとすると、コンパレータCPAとCPBの出力から8ビットのバス幅領域であることを認識し、制御信号BSとして、最初の1メモリサイクルでは信号Lを論理“1”に、信号UとU'を論理“0”にする。これにより、上記クロックドインバータ回路CN0とCN1のみが動作状態になる。したがって、内部データバスDBの下位8ビットの信号D0～D7は、代表として例示的に示されたクロックドインバータ回路CN0とCN1を通して出力回路DOB0～DOB7の入力に伝えられる。これにより、出力制御信号DOCに従い出力回路DOB0～DOB1

5の動作状態に応じて、1メモリサイクル中にD0～D7からなる8ビットのデータが出力端子OUT0～OUT7を通して16ビット幅のシステムバスADBのうちの下位8ビットへ送出される。システムバスADBの上位8ビットに対応した出力端子OUT8～OUT15は、上記クロックドインバータ回路CN2ないしCN5の出力がハイインピーダンスになることに応じて同図ではハイインピーダンスとして示しているが、実際には出力下位DOB8ないしDOB15が出力制御信号DOCにより動作するので、無意味なデータが出力される。しかし、このメモリサイクル中でアクセスされる周辺デバイスは、上記8ビットのバスインターフェイスをもつものであるから問題ない。したがって、クロックドインバータ回路CN0とCN3の制御端子を共通にして制御信号Lを供給する構成としてもよい。

次の1メモリサイクルでは信号U'を論理“1”に、信号LとUを論理“0”にする。これにより、上記クロックドインバータ回路CN4とC

N<sub>5</sub>のみが動作状態になる。したがって、内部データバスDBの上位8ビットの信号D<sub>8</sub>～D<sub>15</sub>は、代表として例示的に示されたクロックドインバータ回路CN<sub>4</sub>とCN<sub>5</sub>を通して出力回路DOB<sub>0</sub>～DOB<sub>7</sub>の入力に伝えられる。これにより、出力制御信号DOCに従い出力回路DOB<sub>0</sub>～DOB<sub>15</sub>の動作状態に応じて、1メモリサイクル中にD<sub>8</sub>～D<sub>15</sub>からなる残り8ビットのデータが出力端子OUT<sub>0</sub>～OUT<sub>7</sub>を通して16ビット幅のシステムバスADBのうちの下位8ビットへ送出される。このようにして、上記レジスタRAとRBにより指定された領域においては、2つのメモリサイクルにより8ビットのバスインターフェイスが実施される。

なお、入出力バッファIOBのうち、入力回路では、上記出力端子OUT<sub>0</sub>ないしOUT<sub>15</sub>が入力端子として用いられ、入力バッファと、その出力を上記内部データバスDBに選択的に伝える上記同様なクロックドインバータ回路からなるマルチブレクサ回路が設けられる。例えば、第3図

OM(リード・オンリー・メモリ)のような記憶回路や、直接メモリアクセス制御回路DMAC、入出力ポートPOT、タイマー回路TM、シリアル・コミュニケーション・インターフェイスSCI等の周辺回路を備えるものである。

実行ユニットに上記コンパレータCPAやCPBが設けられる。そして、レジスタRAやRBは、実行ユニットに含まれるもの他、RAMの特定アドレスをレジスタRAとRBとして用いるものであってもよい。また、上記8ビット／16ビットのバス幅切り換えは、入出力ポートPOTに設けられるものである。

上記の実施例から得られる作用効果は、下記の通りである。すなわち、

(1)内蔵のレジスタによって特定アドレス領域を指定し、この特定アドレス領域内に対するアクセスを認識してその結果に応じてデータバス幅を動的に切り換える。この構成では、マイクロプロセッサ自身が指定アドレスと設定された特定アドレス領域であるかを認識し、それに応じてバス幅を切

において、内部データバスD<sub>0</sub>～D<sub>15</sub>をシステムバス側とみなし、出力回路DOB<sub>0</sub>ないしDOB<sub>15</sub>を内部データバス側とみなしたと等価なマルチブレクサ回路を設けるようにすればよい。

この実施例では、レジスタRAとRBに任意のアドレス情報を書き込むことができるから、ユーザーの領域指定に自由度が増す。また、すべてのバスサイクルに対して有効なので、特定の命令だけとかデータ転送時のみとかいう制約が一切ない。さらに、マイクロプロセッサの内部で信号をデコードしているので高速アクセスが可能となり、チップ外部の信号をデコードする場合のようなスピードの制約を受けない。

第5図には、この発明に用いられるマイクロプロセッサの一実施例の概略ブロック図が示されている。この実施例では、命令の取り込み及びマイクロROM制御部と、そのアドレスデコーダ、マイクロROM、マイクロ命令の命令デコーダ、及びその実行ユニットからなるマイクロプロセッサに、RAM(ランダム・アクセス・メモリ)やR

り換えるので高速でかつ、汎用性をもったバスサイズの切り換えが可能になるという効果が得られる。

(2)上記アドレス指定によりバス幅を切り換えるものであるから、特定の命令だけとかデータ転送時のみとかいった制約がなく、高い汎用性を実現できるという効果が得られる。

(3)上記(1)により、16ビットのアーキテクチャを持つマイクロプロセッサと、既存の豊富な8ビットのアーキテクチャを持つ周辺デバイスを組み合わせてシステムを構成できるという効果が得られる。

以上本発明者によってなされた発明を実施例に基づき具体的に説明したが、本願発明は前記実施例に限定されるものではなく、その要旨を逸脱しない範囲で種々変更可能であることはいうまでもない。例えば、バスサイズの切り換えを行うもの他、バスサイクルを切り換えるようにするものであってもよい。例えば、高速メモリと低速メモリとを混在させてシステムを構成したとき、レジス

タ R A と R B により低速メモリが割り当てられたアドレス空間を指定し、低速度メモリの動作速度に対応してバスサイクルを低速バスサイクルに切り換えるようにするものである。この構成では、従来のように WAIT 信号を入力したり、 VPA 信号を入力したりする必要がない。また、プログラムブルウェイトという方法もあるが、これだと全領域が対象なり、特定領域だけ低速バスサイクルにすることができない。

この発明は、内部 16 ビット構成のマイクロプロセッサの他、8 ビットや 32 ビット構成の各種汎用マイクロプロセッサの他、特殊プロセッサ等に利用するものであってもよい。

#### (発明の効果)

本願において開示される発明のうち代表的なものによって得られる効果を簡単に説明すれば、下記の通りである。すなわち、内蔵のレジスタによって特定アドレス領域を指定し、この特定アドレス領域内に対するアクセスを認識してその結果に応じてデータバスサイズやバスサイクルを動的に

切り換える。この構成では、マイクロプロセッサ自身が指定アドレスと設定された特定アドレス領域であるかを認識し、それに応じてバス幅やバスサイクルを切り換えるので高速でかつ、汎用性をもったバスサイズやバスサイクルの切り換えが可能になる。

#### 4. 図面の簡単な説明

第 1 図は、この発明に係るマイクロプロセッサの一実施例を示すブロック図、

第 2 図は、そのアドレス空間の一例を示す概念図、

第 3 図は、バス幅切り換え機能を持つ入出力バッファ I/O B のうち出力経路の一実施例を示す回路図、

第 4 図は、その動作の一例を説明するためのタイミング図、

第 5 図は、この発明が適用されるマイクロプロセッサの一実施例を示すブロック図である。

MPU … マイクロプロセッサ、 CPA, CPB … コンパレータ、 RA, RB … レジスタ、

I/O B … 入出力バッファ、 CN0 ~ CN5 … クロックドインバータ回路、 DOB0 ~ DOB15 … 出力回路、 RAM … ランダム・アクセス・メモリ、 ROM … リード・オンリー・メモリ、 DMA C … 直接メモリアクセス制御回路、 P0T … 入出力ポート、 TM … タイマー回路、 SCI … シリアル・コミュニケーション・インターフェイス

代理人弁理士 德若 光政

第 1 図



第 2 図



第3図



第4図



第5図

